/*
 封装一个SqliteHelper类，提供简单的sqlite数据库操作接口，完成数据库的基础增删查改
 1.创建、打开数据库文件
 2.对打开的数据库文件进行操作
    1.表的操作
    2.数据的操作
 3.关闭数据库
*/
#pragma once
#include <string>
#include <vector>
#include <iostream>
#include <sqlite3.h>
class SqliteHelper
{
public:
    typedef int (*SqliteCallback)(void *, int, char **, char **);
    SqliteHelper(const std::string &dbfile)
        : _dbfile(dbfile), _handler(nullptr)
    {
    }
    bool open(int safe_leve = SQLITE_OPEN_FULLMUTEX)
    {
        int ret = sqlite3_open_v2(_dbfile.c_str(), &_handler, SQLITE_OPEN_READWRITE | SQLITE_OPEN_CREATE | safe_leve, nullptr);
        if (ret != SQLITE_OK)
        {
            std::cout << "创建/打开数据库失败:";
            std ::cout << sqlite3_errmsg(_handler) << std::endl;
            return false;
        }
        return true;
    }

    bool exec(const std::string &sql, SqliteCallback cb, void *arg)
    {
        int ret = sqlite3_exec(_handler, sql.c_str(), cb, arg, nullptr);
        if (ret != SQLITE_OK)
        {
            std::cout << sql << std::endl;
            std::cout << "语句执行失败: ";
            std::cout << sqlite3_errmsg(_handler) << std::endl;
            return false;
        }
        return true;
    }
    void close()
    {
        sqlite3_close_v2(_handler);
    }

private:
    sqlite3 *_handler;
    std::string _dbfile;
};